package com.guigu.eduservice.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;

import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * <p>
 * 求购信息表（存储买家发布的二手机械求购需求）
 * </p>
 *
 * @author janecraft
 * @since 2025-09-27
 */
@TableName("purchase_demand")
@Data
public class PurchaseDemand implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 求购信息唯一标识
     */
    @TableId(value = "purchase_id", type = IdType.AUTO)
    private Long purchaseId;

    /**
     * 关联用户表user_id（求购信息发布者）
     */
    private Long userId;

    /**
     * 求购设备类型（如挖掘机、装载机）
     */
    private Long typeId;

    /**
     * 求购设备品牌（可选，如"优先三一"）
     */
    private String brand;

    /**
     * 求购设备型号（可选，如"SY215C"）
     */
    private String model;

    /**
     * 期望价格（单位：元，买家可接受的最高价格）
     */
    private BigDecimal expectedPrice;

    /**
     * 期望设备年份（可选，如"2018年以后"）
     */
    private Integer expectedYear;

    /**
     * 设备参数要求（如"使用小时数不超过5000小时"）
     */
    private String parameterRequirement;

    /**
     * 联系人（求购咨询的对接人）
     */
    private String contactName;

    /**
     * 联系电话（求购咨询的联系方式）
     */
    private String contactPhone;

    /**
     * 求购状态（0-待处理，1-已分配，2-已成交，3-已取消）
     */
    private int purchaseStatus;

    /**
     * 关联业务员表businessman_id（purchase_status=1时必填，负责跟进求购需求）
     */
    private Long businessmanId;

    /**
     * 发布时间（用户提交求购信息的时间）
     */
    private LocalDateTime releaseTime;

    /**
     * 记录创建时间
     */
    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    /**
     * 记录更新时间
     */
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;

    @TableField(exist = false)
    private User user;

    @TableField(exist = false)
    private EquipmentType type;

}
